package com.bzkj.document.mapper;

import com.bzkj.document.domain.finishedproduct.dto.FinishedProductDTO;
import com.bzkj.document.domain.finishedproduct.vo.FinishedProductBodyVo;
import com.bzkj.document.domain.finishedproduct.vo.FinishedProductHeadVo;
import org.apache.ibatis.annotations.Param;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @projectName: bzkj-wms
 * @package: com.bzkj.document.mapper
 * @className: FinishedProductInMapper
 * @description: 产成品入库单据持久层
 * @author: C1309
 * @createDate: 2024年11月28日
 * @version: v1.0
 */
public interface FinishedProductInMapper {
    /**
     * 新增产成品入库单据表头
     *
     * @param finishedProductHeader 新增产成品入库单据表头
     * @return 影响行数
     */
    int addFinishedProductHeader(Map<String, Object> finishedProductHeader);

    /**
     * 新增产成品入库单据表体
     *
     * @param finishedProductDetails 新增产成品入库单据表体
     * @return 影响行数
     */
    int addFinishedProductDetails(Map<String, Object> finishedProductDetails);

    /**
     * 获取单据状态
     *
     * @param cgeneralhid 单据头ID
     * @return 单据状态
     */
    HashMap<String, String> getBillStatus(String cgeneralhid);

    /**
     * 更新单据状态
     *
     * @param cgeneralhid 单据号主键
     * @param billState   状态
     * @param userName    操作人
     * @param reason      删除原因
     * @return 影响行数
     */
    int updateBillState(@Param("cgeneralhid") String cgeneralhid,
                        @Param("billState") String billState,
                        @Param("userName") String userName,
                        @Param("reason") String reason);

    /**
     * 判断单据号是否已存在
     *
     * @param vBillCode 单据号
     * @return 影响行数
     */
    int getBillIsExist(String vBillCode);

    /**
     * 查询本地产成品入库单据表头
     *
     * @param finishedProductDTO 查询条件
     * @return 查询结果
     */
    List<FinishedProductHeadVo> queryFinishedProductHeader(FinishedProductDTO finishedProductDTO);

    /**
     * 根据单据号查询本地产成品入库单据表头
     *
     * @param cgeneralhid 单据主键
     * @return 查询结果
     */
    FinishedProductHeadVo selectFinishedInHeaderByBillCode(String cgeneralhid);

    /**
     * 查询本地产成品入库单据表体
     *
     * @param cgeneralhid 单据订单行主键
     * @param billState   单据状态
     * @return 查询结果
     */
    List<FinishedProductBodyVo> selectFinishedProductDetails(@Param("cgeneralhid") String cgeneralhid,
                                                             @Param("billState") String billState);

    /**
     * 更新本地产成品入库单据表头
     *
     * @param finishedProductHeader 表头数据
     * @return 影响行数
     */
    int updateFinishedProductHeader(Map<String, Object> finishedProductHeader);

    /**
     * 更新本地产成品入库单据表体
     *
     * @param finishedProductDetails 表体数据
     * @return 影响行数
     */
    int updateFinishedProductDetails(HashMap<String, Object> finishedProductDetails);

    /**
     * 产成品入库单表头撤销
     *
     * @param headerId 表头主键
     * @param userName 操作人
     * @return 操作结果
     */
    int orderBackHead(@Param("headerId") String headerId, @Param("userName") String userName);

    /**
     * 产成品入库单明细撤销
     *
     * @param headerId 表头主键
     * @param userName 操作人
     * @return 操作结果
     */
    int orderBackDetails(@Param("headerId") String headerId, @Param("userName") String userName);
}
